<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Proxy</title>
</head>
<body>
    <div id="app">
        Hello
    </div>
    <script>
        let data = {
            message: 'Husky',
            count: 1
        }
        // 模拟 Vue 实例
        let vm = new Proxy(data, {
            // 执行代理行为的函数
            // 当访问 vm 的成员会执行
            get(target, key){
                console.log(`get ${key}:`, target[key])
                return target[key]
            },
            // 当设置 vm 的成员会执行
            set(target, key, newValue){
                console.log(`set ${key}:`, newValue)
                if(target[key] === newValue) return
                target[key] = newValue
                document.querySelector('#app').textContent = target[key]
            }
        })

        // 测试
        vm.message = 'Husky1'
        console.log(vm.message)
    </script>
</body>
</html>